<template>
	<view class="login-container">
		<uni-icons type="contact-filled" size="100" color="#AFAFAF"></uni-icons>
		<button type="primary" class="btn-login" @click="getUserProfile">一键登录</button>
		<text class="tips-text">登录后尽享更多福利</text>
	</view>
</template>

<script>
import { mapMutations, mapState } from 'vuex';
export default {
	name: 'my-login',
	data() {
		return {};
	},
	computed: {
		...mapState('m_user', ['redirectInfo']),
	},
	methods: {
		...mapMutations('m_user', ['updateUserInfo', 'updateToken', 'updateRedirectInfo']),
		// 用户授权之后, 获取用户的基本信息
		getUserProfile(e) {
			// console.log(e);

			uni.getUserProfile({
				desc: '用于完善个人资料', // 声明获取用户个人信息后的用途，后续会展示在弹窗中，请谨慎填写
				success: (res) => {
					// 3. 将用户的基本信息存储到 vuex 中
					this.updateUserInfo(res.userInfo);

					// 获取登录成功后的 Token 字符串
					this.getToken(res);
				},
				fail: (res) => {
					return uni.$showMsg('您取消了登录授权');
				},
			});

			console.log(e.detail.userInfo);
			this.updateUserInfo(e.detail.userInfo);

			// 调用获取 Token 的方法
			this.getToken(e.detail);
		},

		// 获取 Token 的方法
		async getToken(info) {
			// 获取 code 对应的值
			const [err, res] = await uni.login().catch((err) => err);

			// console.log(res);
			if (err || res.errMsg !== 'login:ok') return uni.$showMsg('登录失败');

			// console.log(res.code);
			// console.log(info);

			// 准备参数
			const query = {
				code: res.code,
				encryptedData: info.encryptedData,
				iv: info.iv,
				rawData: info.rawData,
				signature: info.signature,
			};

			// console.log(query);
			const { data: loginResult } = await uni.$http.post(
				'/api/public/v1/users/wxlogin',
				query
			);
			console.log(loginResult);
			if (loginResult.meta.status !== 200) return uni.$showMsg('登录失败');

			// uni.$showMsg('登录成功');
			this.updateToken(loginResult.message.token);

			// 调用重新跳转到进入登录之前页面的方法
			this.navigateBack();
		},
		// 跳转到进入登录页面之前的页面方法
		navigateBack() {
			if (this.redirectInfo && this.redirectInfo.openType === 'switchTab') {
				uni.switchTab({
					url: this.redirectInfo.from,
					complete: () => {
						this.updateRedirectInfo(null);
					},
				});
			}
		},
	},
};
</script>

<style lang="scss">
.login-container {
	height: 750rpx;
	background-color: #f8f8f8;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;

	&::after {
		content: ' ';
		display: block;
		width: 100%;
		height: 40px;
		background-color: white;
		position: absolute;
		bottom: 0;
		left: 0;
		border-radius: 100%;
		transform: translateY(50%);
	}
	.btn-login {
		width: 90%;
		border-radius: 100px;
		margin: 15px 0;
		background-color: #c00000;
	}
	.tips-text {
		font-size: 12px;
		color: gray;
	}
}
</style>
